<template>
  <div>
    <div class="bg-white grid-content">
      <div style="overflow: hidden">
        <div class="mytitle">
          <svg-icon icon-class="yjbb" class="myIcon" /> 党员名册数据审核
        </div>
      </div>
      <!-- 表格 -->
      <el-table
        :data="tableData"
        border
        style="width: 100%"
        :header-cell-style="{ background: '#f5f7fa', color: '#909399' }"
      >
        <el-table-column type="index" label="序号" :index="indexMethod">
        </el-table-column>
        <el-table-column align="center" prop="szzb" label="所在支部">
        </el-table-column>
        <el-table-column align="center" prop="name" label="姓名">
        </el-table-column>
        <el-table-column align="center" prop="ygbh" label="员工编号">
        </el-table-column>
        <el-table-column align="center" prop="sfzh" label="身份证号">
        </el-table-column>
        <el-table-column align="center" prop="sex" label="性别">
        </el-table-column>
        <el-table-column align="center" prop="csrq" label="出生日期">
        </el-table-column>
        <el-table-column align="center" prop="xl" label="学历">
        </el-table-column>
        <el-table-column align="center" prop="zgxw" label="最高学位">
        </el-table-column>
        <el-table-column align="center" prop="mz" label="民族">
        </el-table-column>
        <el-table-column align="center" prop="jg" label="籍贯">
        </el-table-column>
        <el-table-column align="center" prop="telephone" label="手机">
        </el-table-column>
        <el-table-column align="center" prop="email" label="邮箱">
        </el-table-column>
        <el-table-column align="center" prop="gzdw" label="工作单位">
        </el-table-column>
        <el-table-column align="center" prop="jtzz" label="家庭住址">
        </el-table-column>
        <el-table-column align="center" prop="rylb" label="人员类别">
        </el-table-column>
        <el-table-column align="center" prop="jrdzzrq" label="加入党组织日期">
        </el-table-column>
        <el-table-column align="center" prop="zzrq" label="转正日期">
        </el-table-column>
        <el-table-column align="center" prop="rysf" label="人员身份">
        </el-table-column>

        <el-table-column
          align="center"
          fixed="right"
          prop="approveStatus"
          label="审核状态"
        >
          <template slot-scope="scope">
            <el-tag
              :type="
                scope.row.approveStatus == '2'
                  ? 'success'
                  : scope.row.approveStatus == '1'
                  ? 'warning'
                  : scope.row.approveStatus == '0'
                  ? 'info'
                  : 'danger'
              "
              disable-transitions
              >{{
                scope.row.approveStatus == "2"
                  ? "已通过"
                  : scope.row.approveStatus == "1"
                  ? "未审核"
                  : scope.row.approveStatus == "0"
                  ? "未提交"
                  : "未通过"
              }}</el-tag
            >
          </template>
        </el-table-column>

        <el-table-column align="center" fixed="right" label="操作" width="100">
          <template slot-scope="scope">
            <el-button @click="handleClick(scope.row, 'check')" type="text"
              >查看</el-button
            >
            <el-button @click="handleClick(scope.row, 'edit')" type="text"
              >审核</el-button
            >
          </template>
        </el-table-column>
      </el-table>
      <!-- 分页器 -->
      <el-pagination
        align="right"
        background
        @size-change="handleSizeChange"
        @current-change="handleCurrentChange"
        :current-page="pageNo"
        :page-sizes="[5, 10, 20, 30, 40, 50]"
        :page-size="pageSize"
        layout="total, sizes, prev, pager, next, jumper"
        :total="total"
      >
      </el-pagination>
    </div>

    <!-- 弹出框 -->
    <el-dialog
      :title="myDialogTitle"
      :visible.sync="dialogFormVisible"
      :before-close="handleClose"
      :custom-class="saveAsDialog"
    >
      <el-form
        v-show="ischeck"
        :inline="true"
        :model="dymcForm"
        class="demo-form-inline"
        :rules="rules"
        ref="dymcForm"
        :disabled="isInput"
        label-position="left"
        label-width="190px"
      >
        <!-- <el-divider content-position="left">基础信息</el-divider> -->
        <el-divider content-position="left">基础信息</el-divider>
        <el-row>
          <el-col :span="12">
            <el-form-item label="所在支部:">
              <el-input
                v-model="dymcForm.szzb"
                placeholder="请输入所在支部"
              ></el-input>
            </el-form-item>
          </el-col>
        </el-row>
        <el-divider content-position="left">党员信息</el-divider>
        <el-row>
          <el-col :span="12">
            <el-form-item label="姓名:">
              <el-input
                v-model="dymcForm.name"
                placeholder="请输入姓名"
              ></el-input>
            </el-form-item>
          </el-col>
          <el-col :span="12">
            <el-form-item label="员工编号:">
              <el-input
                v-model="dymcForm.ygbh"
                placeholder="请输入编号"
              ></el-input>
            </el-form-item>
          </el-col>
        </el-row>

        <el-row>
          <el-col :span="12">
            <el-form-item label="身份证号:">
              <el-input
                v-model="dymcForm.sfzh"
                placeholder="请输入身份证号"
              ></el-input>
            </el-form-item>
          </el-col>
          <el-col :span="12">
            <el-form-item label="性别">
              <el-radio-group v-model="dymcForm.sex">
                <el-radio label="男"></el-radio>
                <el-radio label="女"></el-radio>
              </el-radio-group>
            </el-form-item>
          </el-col>
        </el-row>

        <el-row>
          <el-col :span="12">
            <el-form-item label="出生日期:">
              <el-date-picker
                v-model="dymcForm.csrq"
                type="datetime"
                placeholder="选择日期时间"
                align="right"
                :picker-options="pickerOptions"
              >
              </el-date-picker>
            </el-form-item>
          </el-col>
          <el-col :span="12">
            <el-form-item label="学历">
              <el-input
                v-model="dymcForm.xl"
                placeholder="请输入学历"
              ></el-input>
            </el-form-item>
          </el-col>
        </el-row>

        <el-row>
          <el-col :span="12">
            <el-form-item label="最高学位">
              <el-input
                v-model="dymcForm.zgxw"
                placeholder="请输入最高学位"
              ></el-input>
            </el-form-item>
          </el-col>
          <el-col :span="12">
            <el-form-item label="民族">
              <el-input
                v-model="dymcForm.mz"
                placeholder="请输入民族"
              ></el-input>
            </el-form-item>
          </el-col>
        </el-row>

        <el-row>
          <el-col :span="12">
            <el-form-item label="籍贯">
              <el-input
                v-model="dymcForm.jg"
                placeholder="请输入籍贯"
              ></el-input>
            </el-form-item>
          </el-col>
          <el-col :span="12">
            <el-form-item label="手机">
              <el-input
                v-model="dymcForm.telephone"
                placeholder="请输入手机号码"
              ></el-input>
            </el-form-item>
          </el-col>
        </el-row>

        <el-row>
          <el-col :span="12">
            <el-form-item label="邮箱">
              <el-input
                v-model="dymcForm.email"
                placeholder="请输入邮箱"
              ></el-input>
            </el-form-item>
          </el-col>
          <el-col :span="12">
            <el-form-item label="工作单位">
              <el-input
                v-model="dymcForm.gzdw"
                placeholder="请输入工作单位"
              ></el-input>
            </el-form-item>
          </el-col>
        </el-row>

        <el-row>
          <el-col :span="12">
            <el-form-item label="家庭住址">
              <el-input
                v-model="dymcForm.jtzz"
                placeholder="请输入家庭住址"
              ></el-input>
            </el-form-item>
          </el-col>
          <el-col :span="12">
            <el-form-item label="人员类别">
              <el-select v-model="dymcForm.rylb" placeholder="请选择人员类别">
                <el-option label="正式党员" value="zsdy"></el-option>
                <el-option label="预备党员" value="ybdy"></el-option>
              </el-select>
            </el-form-item>
          </el-col>
        </el-row>

        <el-row>
          <el-col :span="12">
            <el-form-item label="加入党组织日期:">
              <el-date-picker
                v-model="dymcForm.jrdzzrq"
                type="datetime"
                placeholder="选择日期时间"
                align="right"
                :picker-options="pickerOptions"
              >
              </el-date-picker>
            </el-form-item>
          </el-col>
          <el-col :span="12">
            <el-form-item label="转正日期:">
              <el-date-picker
                v-model="dymcForm.zzrq"
                type="datetime"
                placeholder="选择日期时间"
                align="right"
                :picker-options="pickerOptions"
              >
              </el-date-picker>
            </el-form-item>
          </el-col>
        </el-row>

        <el-row>
          <el-col :span="12">
            <el-form-item label="人员身份">
              <el-select v-model="dymcForm.rysf" placeholder="请选择人员身份">
                <el-option label="生产操作" value="sccz"></el-option>
                <el-option label="技术人员" value="jsry"></el-option>
                <el-option label="管理人员" value="glry"></el-option>
              </el-select>
            </el-form-item>
          </el-col>
        </el-row>
      </el-form>

      <el-form
        v-show="!ischeck"
        :inline="true"
        :model="dymcForm"
        class="demo-form-inline"
        ref="dymcForm"
      >
        <el-form-item label="审核">
          <el-select
            v-model="dymcForm.approveStatus"
            placeholder="请选择审核状态"
          >
            <!-- dymcForm.approveStatus=='0'? dymcForm.approveStatus == '未审核':dymcForm.approveStatus=='1'?dymcForm.approveStatus == '通过':dymcForm.approveStatus == '不通过' -->
            <el-option label="未审核" value="1"></el-option>
            <el-option label="通过" value="2"></el-option>
            <el-option label="不通过" value="3"></el-option>
          </el-select>
        </el-form-item>

        <el-row>
          <el-form-item label="审核备注:">
            <el-input
              v-model="dymcForm.approveBz"
              placeholder="请输入审核备注"
            ></el-input>
          </el-form-item>
        </el-row>
      </el-form>

      <div slot="footer" class="dialog-footer" v-show="!ischeck">
        <el-button @click="close('dymcForm')">取 消</el-button>
        <el-button type="primary" @click="submitForm('dymcForm')"
          >确 定</el-button
        >
      </div>
    </el-dialog>
  </div>
</template>

<script>
import dymcApi from "@/api/dymc";

export default {
  data() {
    return {
      pageNo: 1, //当前页码
      pageSize: 10, //每页显示数量
      total: 0, //总数量
      // table数据
      tableData: [],
      //当前页码
      currentPage: 1,
      //表单填报的数据
      dymcForm: {
        szzb: "", //所在支部
        name: "", //姓名
        ygbh: "", //员工编号
        sfzh: "", //身份证号
        sex: "", //性别
        csrq: "", //出生日期
        xl: "", //学历
        zgxw: "", //最高学位
        mz: "", //民族
        jg: "", //籍贯
        telephone: "", //手机
        email: "", //邮箱
        gzdw: "", //工作单位
        jtzz: "", //家庭住址
        rylb: "", //人员类别
        jrdzzrq: "", //加入党组织日期
        zzrq: "", //转正日期
        rysf: "", //人员身份
      },
      //验证规则
      rules: {
        syjmc: [
          { required: true, message: "请输入水源井名称", trigger: "blur" },
        ],
        ssdw: [{ required: true, message: "请输入所属单位", trigger: "blur" }],
        tcrq: [{ required: true, message: "请选择日期", trigger: "change" }],
      },
      //时间快捷选择
      pickerOptions: {
        // disabledDate(time) {
        //   return time.getTime() > Date.now();
        // },
        shortcuts: [
          {
            text: "今天",
            onClick(picker) {
              picker.$emit("pick", new Date());
            },
          },
          {
            text: "昨天",
            onClick(picker) {
              const date = new Date();
              date.setTime(date.getTime() - 3600 * 1000 * 24);
              picker.$emit("pick", date);
            },
          },
          {
            text: "一周前",
            onClick(picker) {
              const date = new Date();
              date.setTime(date.getTime() - 3600 * 1000 * 24 * 7);
              picker.$emit("pick", date);
            },
          },
        ],
      },
      //获取当前日期
      currentTime: "",
      //
      saveAsDialog: "",
      //编辑框是否显示
      dialogFormVisible: false,
      //弹出框是否是查看
      ischeck: false,
      //控制查看时不可更改数据
      isInput: false,
      //弹出框标题
      myDialogTitle: "",
    };
  },
  created() {
    this.search();
  },
  mounted() {
    this.filterTime();
    // this.initDate();
  },
  // computed:{
  //   isBetterToStr() {
  //     return this.dymcForm.approveStatus.toString()
  //   }
  // },
  methods: {
    /**
     * 查询列表
     */
    async search() {
      // this.pageNo = pageNo; //当前页码
      // this.pageSize = pageSize; //每页显示数量
      //发送查询请求
      let res = await dymcApi.getDymcList(this.pageNo, this.pageSize, 0);
      //判断是否成功
      if (res.success) {
        console.log(res.data);
        //赋值
        this.tableData = res.data.records;
        //总数量
        this.total = res.data.total;
      }
    },
    onSubmit() {
      console.log("submit!");
    },
    //关闭对话框
    handleClose(done) {
      // 清空表单
      // this.$refs['dymcForm'].resetFields();
      // 清空表单校验，避免再次进来会出现上次校验的记录
      this.$refs["dymcForm"].clearValidate();
      done();
    },
    // 弹框关闭触发
    close(formName) {
      this.dialogFormVisible = false;
      // 清空表单校验，避免再次进来会出现上次校验的记录
      this.$refs[formName].clearValidate();
    },

    submitForm(formName) {
      //表单验证
      this.$refs[formName].validate(async (valid) => {
        if (valid) {
          let res = null;
          console.log(this.dymcForm.id + "111");
          //判断菜单ID是否为空
          if (this.dymcForm.id === "") {
            this.dymcForm.rq = this.currentTime;
            //发送添加请求
            res = await dymcApi.addDymc(this.dymcForm);
          } else {
            //发送审核请求
            console.log(334345);
            res = await dymcApi.updateDymc(this.dymcForm);
          }
          console.log(res);
          //判断是否成功
          if (res.success) {
            // this.$message.success(res.message);
            this.$message({ message: "修改审核状态成功！", type: "success" });
            //刷新
            this.search();
            //关闭窗口
            this.dialogFormVisible = false;
          } else {
            console.log(res);
            this.$message.error(res.message);
          }
        }
      });
    },
    handleClick(row, handle) {
      // console.log(row.approveStatus);
      this.dialogFormVisible = true;
      if (handle == "check") {
        this.myDialogTitle = "水源井统计报表";
        this.saveAsDialog = "saveAsDialog1";
        this.ischeck = true;
        this.isInput = true; // 1.表单禁用
        // this.dymcForm = row
        this.$objCopy(row, this.dymcForm); //把当前要编辑的数据复制到数据域，给表单回显
        this.$message({ message: "成功打开", type: "success" });
      } else if (handle == "edit") {
        if (row.approveStatus != 2) {
          this.myDialogTitle = "水源井统计报表审核";
          this.saveAsDialog = "saveAsDialog2";
          this.ischeck = false;
          this.isInput = false;
          this.$objCopy(row, this.dymcForm); //把当前要编辑的数据复制到数据域，给表单回显
          this.dymcForm.approveStatus = row.approveStatus.toString();
        } else {
          this.dialogFormVisible = false;
          this.$message({ message: "已通过不可再审核！", type: "error" });
        }
      }
    },
    /*** 当每页数量发生变化时触发该事件 */
    handleSizeChange(size) {
      console.log(size);
      this.pageSize = size;
      //将每页显示的数量交给成员变量
      this.search(this.pageNo, size);
    },
    /*** 当页码发生变化时触发该事件 */
    handleCurrentChange(page) {
      console.log(page);
      this.pageNo = page;
      //调用查询方法
      this.search(page, this.pageSize);
    },
    // 序号计算
    indexMethod(index) {
      // index默认在0开始，这里+1
      return index + 1 + (this.pageNo - 1) * this.pageSize;
    },
    // 获取当前日期
    filterTime() {
      var date = new Date();
      var y = date.getFullYear();
      var m = date.getMonth() + 1;
      m = m < 10 ? "0" + m : m;
      var d = date.getDate();
      d = d < 10 ? "0" + d : d;
      this.currentTime = y + "-" + m + "-" + d;
    },
  },
};
</script>

<style lang="scss" scoped>
// 标题
.mytitle {
  font-size: large;
  padding-left: 10px;
  margin-bottom: 16px;
  float: left;
}

//按钮组
.myButtons {
  float: right;
}

//格子的样式
.bg-white {
  background: #ffffff;
}

.grid-content {
  padding: 10px;
  margin-bottom: 10px;
  border-radius: 4px;
}

.calendar ::v-deep .el-button-group::before {
  display: none;
}

.calendar ::v-deep .el-button-group::after {
  display: none;
}

// 分割线样式
.el-divider--horizontal {
  display: block;
  height: 2px;
  width: 100%;
  margin: 24px 0;
}

// 表单各项的样式
.el-form-item {
  margin: 15px 10px 15px 10px;
}

//表单禁用字体样式
.el-input.is-disabled ::v-deep .el-input__inner {
  color: #606266;
}
//对话框宽度
// .customWidth{
//         width:80%;
//     }
::v-deep .saveAsDialog1 {
  width: 60% !important;
}
::v-deep .saveAsDialog2 {
  width: 20% !important;
}
//日期选择框宽度
.el-date-editor.el-input,
.el-date-editor.el-input__inner {
  width: 200px;
}

.el-input {
  width: 200px;
}
</style>